Amendments to the Claims: 

This listing of claims will replace all prior versions, and listings, of claims in the 
application: 



1 1 . (canceled) 

2 2. (canceled) 

3 3 . (currently amended) Th e m e thod of claim 1, wh e r e in: A method for automatically 

4 modifying behavior of a compiled application, the method comprising the computer 

5 implemented steps of: 

6 receiving a first set of compiled instructions for the application; 

7 modifying the first set of compiled instructions to generate a modified set of compiled 

8 instructions, including the step of inserting into said first set of compiled 

9 instructions a new set of one or more instructions for invoking a modification 

10 routine that provides new behavior; 

11 wherein the modification routine is not part of the first set of compiled instructions; 

12 wherein the method further comprises the step of parsing the first set of compiled 

13 instructions to identify an entry point to a target routine that exists in the first 

14 set of compiled instructions; and 

15 said step of inserting includes inserting the new set of one or more instructions at a 

16 location in the first set of compiled instructions that is based on where the 

17 entry point to the target routine resides in the first set of instructions. 
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1 4. (original) The method of claim 3, said step of inserting further comprising inserting 

2 the new set of one or more instructions at a location within the first set of instructions that 

3 causes the new set of one or more instructions to be executed immediately after the target 

4 routine is invoked. 

1 5. (original) The method of claim 3, wherein: 

2 the new set of one or more instructions constitutes a first new set of one or more 

3 instructions; and 

4 the method further comprising the steps of: 

5 parsing the first set of compiled instructions to identify an exit point to the 

6 target routine; and 

7 inserting a second new set of one or more instructions at a location in the first 

8 set of compiled instructions that is based on where an exit point to the 

9 target routine resides in the first set of instructions. 

1 6. (original) The method of claim 5, wherein 

2 the modification routine stores a first time value in response to being invoked through 

3 the first new set of one or more instructions; and 

4 the second new set of one or more instructions invokes a second modification routine 

5 for storing a second time value. 

1 7. (original) The method of claim 6, wherein the modification routine is the same as the 

2 second modification routine. 

1 8. (original) The method of claim 6, further comprising the step of measuring 

2 performance of the target routine based on a comparison between the first time value and the 

3 second time value. 
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1 9. (original) The method of claim 8, wherein the second modification routine performs 

2 said step of measuring performance of the target routine. 

1 10. (canceled) 

1 11. (currently amended) The method of claim [[10]] 3 wherein the new set of one or more 

2 instructions are inserted at each location where, within said first set of instructions, resides an 

3 entry point into one of the routines in the first set. 

1 12. (original) The method of claim 11, wherein: 

2 the new set of one or more instructions constitutes a first new set of one or more 

3 instructions; 

4 the method further comprises the step of inserting a second new set of one or more 

5 instructions for every one of the routines in the first set of compiled 

6 instructions; and 

7 the second new set of one or more instructions are inserted at each location in the first 

8 set of compiled instructions where, within said first set of instructions, resides 

9 an exit point from one of the routines in the first set. 

1 13. (original) The method of claim 12, wherein 

2 the modification routine stores a first time value in response to being invoked through 

3 the first new set of one or more instructions; and 

4 the second new set of one or more instructions invokes a second modification routine 

5 for storing a second time value. 
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1 1 4. (currently amended) Th e m e thod of claim 1, A method for automatically modifying 

2 behavior of a compiled application, the method comprising the computer implemented steps 

3 of: 

4 receiving a first set of compiled instructions for the application; 

5 modifying the first set of compiled instructions to generate a modified set of compiled 

6 instructions, including the step of inserting into said first set of compiled 

7 instructions a new set of one or more instructions for invoking a modification 

8 routine that provides new behavior; 

9 wherein the modification routine is not part of the first set of compiled instructions; 

1 0 wherein the new set of one or more instructions are inserted at a location based on 

1 1 where, within said first set of instructions, resides a particular instruction that 

12 is associated with entering a target routine in the first set. 

1 15. (original) The method of claim 14, wherein the one or more instructions cause one or 

2 more functions provided by said target routine to be bypassed. 

3 16. (currently amended) Th e m e thod of claim 1 , A method for automatically modifying 

4 behavior of a compiled application, the method comprising the computer implemented steps 

5 of: 

6 receiving a first set of compiled instructions for the application; 

7 modifying the first set of compiled instructions to generate a modified set of compiled 

8 instructions, including the step of inserting into said first set of compiled 

9 instructions a new set of one or more instructions for invoking a modification 

10 routine that provides new behavior; 

11 wherein the modification routine is not part of the first set of compiled instructions; 
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12 wherein the new set of one or more instructions are inserted at a location based on 

1 3 where, within said first set of instructions, resides a particular instruction that 

14 is associated with exiting a target routine in the first set. 

15 17. (canceled) 

16 18. (currently amended) Th e method of claim 1, A method for automatically modifying 

17 behavior of a compiled application, the method comprising the computer implemented steps 

18 of: 

19 receiving a first set of compiled instructions for the application 

20 modifying the first set of compiled instructions to generate a modified set of compiled 

21 instructions, including the step of inserting into said first set of compiled 

22 instructions a new set of one or more instructions for invoking a modification 

23 routine that provides new behavior; 

24 wherein the modification routine is not part of the first set of compiled instructions; 

25 wherein said step of invoking the modification routine comprises invoking a routine 

26 that accumulates data about performance of the application. 

1 19. (original) The method of claim 18, wherein the data about performance includes data 

2 indicating a number of times a particular set of instructions within said first set of compiled 

3 instructions is executed. 

1 20. (currently amended) The method of claim [[ 1 ]] 18, wherein the modification routine 

2 reports data about performance of the application to a process, other than the application, that 

3 is executing on a network. 

1 21. (canceled) 
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1 22. (original) A method for automatically monitoring performance of a compiled 

2 application, the method comprising the computer implemented steps of: 

3 receiving a first set of compiled instructions for the application; and 

4 generating a modified set of compiled instructions, including: 

5 inserting a first set of one or more instructions for invoking a modification 

6 routine in association with entering a particular routine within the first 

7 set of compiled instructions; and 

8 inserting a second set of one or more instructions that invoke a second 

9 modification routine in association with exiting the particular routine; 

10 wherein the modified set of compiled instructions causes a processor to perform the 

1 1 steps of: 

12 invoking the modification routine when entering the particular routine; and 

1 3 invoking the second modification routine when exiting the particular routine. 

1 23. (original) The method of claim 22, further comprising executing a runtime module 

2 based on the modified set of compiled instructions. 

1 24. (original) The method of claim 22, said step of invoking the modification routine 

2 comprising accumulating first data associated with the particular routine, the first data 

3 indicating at least one of a number of times the particular routine is called and a start time for 

4 the particular routine. 
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1 25. (original) The method of claim 24, said step of invoking the second modification 

2 routine comprising accumulating second data associated with the particular routine, the 

3 second data indicating at least one of a number of times the particular routine has completed, 

4 a number of active calls to the particular routine that have not completed, an end time for the 

5 particular routine, an execution time based on a difference between the start time and the end 

6 time, an average execution time, a minimum execution time, and a maximum execution time. 

1 26. (original) The method of claim 22, said step of invoking the second modification 

2 routine comprising recording data about performance associated with the particular routine. 

1 27. (original) The method of claim 26, wherein said step of recording data about 

2 performance is performed according to a particular schedule based on a time when the second 

3 modification routine is invoked. 

1 28. (original) The method of claim 22, further comprising the step of receiving first data 

2 indicating the particular routine. 

1 29. (original) The method of claim 22, wherein: 

2 the method further comprises receiving first data indicating a plurality of particular 

3 routines in the first set; and 

4 said steps of inserting a first set and inserting a second set are repeated for each 

5 particular routine of the plurality of particular routines. 

1 30. (original) The method of claim 22, said step of invoking the second modification 

2 routine comprises reporting data about performance of the application to a process, other than 

3 the application, that is executing on a network. 

1 31. (original) The method of claim 22, wherein the application provides a service in 

2 response to a request from a client process on a network. 
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1 32. (currently amended) The method of claim 22, wherein the first set of compiled 

2 instructions comprises [[Java]] bytecode. 

1 33. (original) A method for automatically monitoring performance of a compiled 

2 application, the method comprising the computer implemented steps of: 

3 receiving a first set of compiled instructions for the application; 

4 receiving first data indicating a plurality of particular routines in the first set; 

5 generating a modified set of compiled instructions, including: 

6 inserting, for each particular routine of the plurality of particular routines, a 

7 first set of one or more instructions for invoking a modification routine 

8 in association with entering the particular routine within the first set of 

9 compiled instructions; and 

10 inserting, for each particular routine of the plurality of particular routines, a 

1 1 second set of one or more instructions that invoke a second 

12 modification routine in association with exiting the particular routine; 

13 and 

14 executing a runtime module based on the modified set of compiled instructions to 

1 5 cause a processor to perform the steps of: 

16 invoking the modification routine when entering the particular routine for 

1 7 accumulating first data associated with the particular routine, the first 

1 8 data indicating at least one of a number of times the particular routine 

19 is called and a start time for the particular routine; and 

20 invoking the second modification routine when exiting the particular routine 

21 for 
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22 accumulating second data associated with the particular routine, the 

23 second data indicating at least one of a number of times the 

24 particular routine has completed, a number of active calls to the 

25 particular routine that have not completed, an end time for the 

26 particular routine, an execution time based on a difference 

27 between the start time and the end time, an average execution 

28 time, a minimum execution time, and a maximum execution 

29 time, and 

30 recording data about performance based on the first data and the 

3 1 second data according to a particular schedule based on a time 

32 when the second modification routine is invoked. 

1 34. (canceled) 

2 35. (canceled) 

1 36. (currently amended) The computer r e adabl e m e dium of claim 3 4 , wh e r e in: A 

2 computer-readable medium carrying one or more sequences of instructions for automatically 

3 modifying behavior of a compiled application, wherein execution of the one or more 

4 sequences of instructions by one or more processors causes the one or more processors to 

5 perform the steps of: 

6 receiving a first set of compiled instructions for the application; 

7 modifying the first set of compiled instructions to generate a modified set of compiled 

8 instructions, including the step of inserting a new set of one or more 

9 instructions for invoking a modification routine that provides new behavior; 

10 wherein the modification routine is not part of the first set of compiled instructions; 
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1 1 wherein execution of the one or more sequences of instructions by one or more 

12 processors causes the one or more processors to further perform the step of 

13 parsing the first set of compiled instructions to identify an entry point to a 

14 target routine that exists in the first set of compiled instructions; and 

15 said step of inserting includes inserting the new set of one or more instructions at a 

16 location in the first set of compiled instructions that is based on where the 

1 7 entry point to the target routine resides in the first set of instructions. 

1 37. (original) The computer-readable medium of claim 36, said step of inserting further 

2 comprising inserting the new set of one or more instructions at a location within the first set 

3 of instructions that causes the new set of one or more instructions to be executed immediately 

4 after the target routine is invoked. 

1 38. (original) The computer-readable medium of claim 36, wherein: 

2 the new set of one or more instructions constitutes a first new set of one or more 

3 instructions; and 

4 execution of the one or more sequences of instructions by one or more processors 

5 causes the one or more processors to further perform the steps of: 

6 parsing the first set of compiled instructions to identify an exit point to the 

7 target routine; and 

8 inserting a second new set of one or more instructions at a location in the first 

9 set of compiled instructions that is based on where an exit point to the 
10 target routine resides in the first set of instructions. 

1 39. (original) The computer-readable medium of claim 38, wherein 

2 the modification routine stores a first time value in response to being invoked through 

3 the first new set of one or more instructions; and 
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4 the second new set of one or more instructions invokes a second modification routine 

5 for storing a second time value. 

1 40. (original) The computer-readable medium of claim 39, wherein the modification 

2 routine is the same as the second modification routine. 

1 41. (original) The computer-readable medium of claim 39, wherein execution of the one 

2 or more sequences of instructions by one or more processors causes the one or more 

3 processors to further perform the step of measuring performance of the target routine based 

4 on a comparison between the first time value and the second time value. 

1 42. (original) The computer-readable medium of claim 41, wherein the second 

2 modification routine performs said step of measuring performance of the target routine. 

1 43. (canceled) 

2 44. (currently amended) The computer-readable medium of claim [[43]] 36, wherein the 

3 new set of one or more instructions are inserted at each location where, within said first set of 

4 instructions, resides an entry point into one of the routines in the first set. 

1 45 . (original) The computer-readable medium of claim 44, wherein: 

2 the new set of one or more instructions constitutes a first new set of one or more 

3 instructions; 

4 execution of the one or more sequences of instructions by one or more processors 

5 further causes the one or more processors to perform the step of inserting a 

6 second new set of one or more instructions for every one of the routines in the 

7 first set of compiled instructions; and 
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8 the second new set of one or more instructions are inserted at each location in the first 

9 set of compiled instructions where, within said first set of instructions, resides 
10 an exit point from one of the routines in the first set. 

1 46. (original) The computer-readable medium of claim 45, wherein 

2 the modification routine stores a first time value in response to being invoked through 

3 the first new set of one or more instructions; and 

4 the second new set of one or more instructions invokes a second modification routine 

5 routine for storing a second time value. 

1 47. (currently amended) Th e comput e r r e adabl e m e dium of claim 4 7, A computer- 

2 readable medium carrying one or more sequences of instructions for automatically modifying 

3 behavior of a compiled application, wherein execution of the one or more sequences of 

4 instructions by one or more processors causes the one or more processors to perform the steps 

5 of 

6 receiving a first set of compiled instructions for the application; 

7 modifying the first set of compiled instructions to generate a modified set of compiled 

8 instructions, including the step of inserting a new set of one or more 

9 instructions for invoking a modification routine that provides new behavior; 

10 wherein the modification routine is not part of the first set of compiled instructions; 

1 1 wherein the new set of one or more instructions are inserted at a location based on 

12 where, within said first set of instructions, resides a particular instruction that 

13 is associated with entering a target routine in the first set. 

1 48. (original) The computer-readable medium of claim 47, wherein the one or more 

2 instructions cause one or more functions provided by said target routine to be bypassed. 
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1 49. (currently amended) Th e comput e r r e adabl e m e dium of claim 3 4 , A computer- 

2 readable medium carrying one or more sequences of instructions for automatically modifying 

3 behavior of a compiled application, wherein execution of the one or more sequences of 

4 instructions by one or more processors causes the one or more processors to perform the steps 

5 of 

6 receiving a first set of compiled instructions for the application; 

7 modifying the first set of compiled instructions to generate a modified set of compiled 

8 instructions, including the step of inserting a new set of one or more 

9 instructions for invoking a modification routine that provides new behavior; 

10 wherein the modification routine is not part of the first set of compiled instructions; 

1 1 wherein the new set of one or more instructions are inserted at a location based on 

12 where, within said first set of instructions, resides a particular instruction that 

13 is associated with exiting a target routine in the first set. 

1 50. (canceled) 

1 51. (currently amended) Th e comput e r r e adabl e m e dium of claim 3 4 , A computer- 

2 readable medium carrying one or more sequences of instructions for automatically modifying 

3 behavior of a compiled application, wherein execution of the one or more sequences of 

4 instructions by one or more processors causes the one or more processors to perform the steps 

5 of 

6 receiving a first set of compiled instructions for the application; 

7 modifying the first set of compiled instructions to generate a modified set of compiled 

8 instructions, including the step of inserting a new set of one or more 

9 instructions for invoking a modification routine that provides new behavior; 
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10 wherein the modification routine is not part of the first set of compiled instructions; 

1 1 wherein said step of invoking the modification routine comprises invoking a routine 

12 that accumulates data about performance of the application. 

1 52. (original) The computer-readable medium of claim 5 1 , wherein the data about 

2 performance includes data indicating a number of times a particular set of instructions within 

3 said first set of compiled instructions is executed. 

1 53. (original) The computer-readable medium of claim 5 1 , wherein the modification 



2 routine reports data about performance of the application to a process, other than the 

3 application, executing on a network. 

1 54. (canceled) 



1 55. (original) A computer-readable medium carrying one or more sequences of 

2 instructions for automatically monitoring performance of a compiled application, wherein 

3 execution of the one or more sequences of instructions by one or more processors causes the 

4 one or more processors to perform the steps of: 

5 receiving a first set of compiled instructions for the application; and 

6 generating a modified set of compiled instructions, including: 

7 inserting a first set of one or more instructions for invoking a modification 

8 routine in association with entering a particular routine within the first 

9 set of compiled instructions; and 

10 inserting a second set of one or more instructions that invoke a second 

1 1 modification routine in association with exiting the particular routine; 

12 wherein the modified set of compiled instructions causes a processor to perform the 

13 steps of: 

14 invoking the modification routine when entering the particular routine; and 
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15 invoking the second modification routine when exiting the particular routine. 

1 56. (original) The computer-readable medium of claim 55, wherein execution of the one 

2 or more sequences of instructions by one or more processors further causes the one or more 

3 processors to perform the step of executing a runtime module based on the modified set of 

4 compiled instructions. 

1 57. (original) The computer-readable medium of claim 55, said step of invoking the 

2 modification routine comprising accumulating first data associated with the particular routine, 

3 the first data indicating at least one of a number of times the particular routine is called and a 

4 start time for the particular routine. 

1 58. (original) The computer-readable medium of claim 57, said step of invoking the 

2 second modification routine comprising accumulating second data associated with the 

3 particular routine, the second data indicating at least one of a number of times the particular 

4 routine has completed, a number of active calls to the particular routine that have not 

5 completed, an end time for the particular routine, an execution time based on a difference 

6 between the start time and the end time, an average execution time, a minimum execution 

7 time, and a maximum execution time. 

1 59. (original) The computer-readable medium of claim 55, said step of invoking the 

2 second modification routine comprising recording data about performance associated with the 

3 particular routine. 

1 60. (original) The computer-readable medium of claim 59, wherein said step of recording 

2 data about performance is performed according to a particular schedule based on a time when 

3 the second modification routine is invoked. 
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1 61 . (original) The computer-readable medium of claim 55, wherein execution of the one 

2 or more sequences of instructions by one or more processors further causes the one or more 

3 processors to perform the step of receiving first data indicating the particular routine. 

1 62. (original) The computer-readable medium of claim 55, wherein: 

2 execution of the one or more sequences of instructions by one or more processors 

3 further causes the one or more processors to perform the step of receiving first 

4 data indicating a plurality of particular routines in the first set; and 

5 said steps of inserting a first set and inserting a second set are repeated for each 

6 particular routine of the plurality of particular routines. 

1 63. (original) The computer-readable medium of claim 55, said step of invoking the 

2 second modification routine comprises reporting data about performance of the application to 

3 a process, other than the application, that is executing on a network. 

1 64. (original) The computer-readable medium of claim 55, wherein the application provides 

2 a service in response to a request from a client process on a network. 

1 65. (currently amended) The computer-readable medium of claim 55, wherein the first set 

2 of compiled instructions comprises [[Java]] bytecode. 
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